<script setup lang="ts">
import { onMounted, ref } from "vue";

import * as echarts from "echarts";

let charts = ref();

onMounted(() => {
  // 初始化
  let myChart = echarts.init(charts.value);
  // 配置项
  myChart.setOption({
    // 标题组件
    tooltip: {
      trigger: "item", // 触发类型
    },
    // 图例组件的配置
    legend: {
      top: "5%", // 图例距离顶部的距离
      right: "5%", // 图例距离左的距离
      orient: "vertical", // 图例列表的布局朝向
      textStyle: {
        color: "#fee", // 图例的字体颜色
      },
    },
    series: [
      {
        name: "年龄比例", // 系列名称
        type: "pie", // 饼图
        radius: ["40%", "70%"], // 饼图的半径
        avoidLabelOverlap: false, // 是否启用防止标签重叠策略
        // 图形上的文本标签
        itemStyle: {
          borderRadius: 10, // 图形的圆角
          borderColor: "#666", // 图形的描边颜色
          borderWidth: 2, // 图形的描边宽度
        },
        //  高亮的扇区和标签样式。
        label: {
          show: false, // 是否显示标签
          position: "inside", // 标签文字的展示位置
        },
        emphasis: {
          label: {
            show: true, // 强调的时候是否显示标签
            fontSize: 20, // 强调时标签的字体大小
            color: "#fff", // 强调时标签的字体颜色
            fontWeight: "bold", // 强调时标签的字体粗细
          },
        },
        labelLine: {
          show: false,
        },
        data: [
          { value: 1048, name: "10岁以下" },
          { value: 735, name: "10岁到20岁" },
          { value: 580, name: "20岁到30岁" },
          { value: 484, name: "30岁到40岁" },
          { value: 300, name: "40岁以上" },
        ],
      },
    ],
    grid: {
      left: 0,
      right: 0,
      bottom: 0,
      top: 0,
    },
  });
});

defineOptions({
  name: "Age",
});
</script>

<template>
  <div class="box2">
    <div class="title">
      <p>年龄比例</p>
      <img src="../../images/dataScreen-title.png" alt="" />
    </div>
    <!--  图形的容器必须有高度，不然什么都看不见  -->
    <div class="charts" ref="charts"></div>
  </div>
</template>

<style scoped lang="scss">
.box2 {
  margin-top: 10px;
  margin-bottom: 10px;
  width: 100%;
  height: 400px;
  background: url("../../images/dataScreen-main-cb.png") no-repeat;
  background-size: cover;
  .title {
    margin-left: 20px;
    margin-top: 10px;
    p {
      color: white;
      font-size: 16px;
    }
  }

  .charts {
    width: 100%;
    height: 200px;
    left: -50px;
    margin-top: 10px;
  }
}
</style>
